package com.ruoyi.system.mapper;

import java.util.List;
import com.ruoyi.system.domain.CouponInfo;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;

/**
 * 优惠卷管理Mapper接口
 *
 * @author ruoyi
 * @date 2024-10-19
 */
@Mapper
public interface CouponInfoMapper
{
    /**
     * 查询优惠卷管理
     *
     * @param couponInfoId 优惠卷管理主键
     * @return 优惠卷管理
     */
    public CouponInfo selectById(Long couponInfoId);

    /**
     * 查询优惠卷管理列表
     *
     * @param couponInfo 优惠卷管理
     * @return 优惠卷管理集合
     */
    public List<CouponInfo> select(CouponInfo couponInfo);

    /**
     * 新增优惠卷管理
     *
     * @param couponInfo 优惠卷管理
     * @return 结果
     */
    public int insert(CouponInfo couponInfo);

    /**
     * 修改优惠卷管理
     *
     * @param couponInfo 优惠卷管理
     * @return 结果
     */
    public int update(CouponInfo couponInfo);

    /**
     * 删除优惠卷管理
     *
     * @param couponInfoId 优惠卷管理主键
     * @return 结果
     */
    public int deleteById(Long couponInfoId);

    /**
     * 批量删除优惠卷管理
     *
     * @param couponInfoIds 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteByIds(Long[] couponInfoIds);

    /**
     * todo 查询可发放优惠券
     * @param couponInfoId
     * @return
     */
    CouponInfo selectCouponInfoByCouponInfoId(Long couponInfoId);

    /**
     * @description: //TODO 发放优惠券修改状态为正在发放
     * @author: Mr.Zhang
     * @param: [couponInfoId, status]
     * @return: int
     **/
    @Update("update coupon_info set `status` = #{status} where coupon_info_id = #{couponInfoId}")
    int startCoupons(@Param("couponInfoId") Long couponInfoId, @Param("status") int status);

    /**
     * todo 领取成功 修改优惠券数量
     * @param couponInfoId
     * @param count
     */
    @Update("update coupon_info set release_num = #{count} where coupon_info_id = #{couponInfoId} and release_num >0")
    void updateCouponInfoById(@Param("couponInfoId") Long couponInfoId, @Param("count") Long count);

    /**
     * todo 前端抢券的列表
     * @return
     */
    @Select("select * from coupon_info where `status` = 1")
    List<CouponInfo> couponsList();

}
